The menu, as designed, is a 1-tier menu (or is it 2-tier). It has the horizontal menu bar, along with the drop downs... but the drop downs aren't designed to propogate another menu (3rd teir). I was wondering if, but looking at the code I've got, anyone could see a *relatively* easy way to make this menu a three tier:
Here's the code:
Expand|Select|Wrap|Line Numbers
- /***********************************************
- * AnyLink Drop Down Menu- © Dynamic Drive (www.dynamicdrive.com)
- * This notice MUST stay intact for legal use
- * Visit http://www.dynamicdrive.com/ for full source code
- ***********************************************/
- //Contents for Ministries Menu
- var menu1=new Array()
- menu1[0]='<a href="#" onclick="return clickreturnvalue()" onmouseover="dropdownmenu(this, event, menu2, '150px')" onmouseout="delayhidemenu()">Worship</a>'
- menu1[1]='<a href="/fellowship.shtml">Fellowship</a>'
- menu1[2]='<a href="/outreach.shtml">Outreach</a>'
- menu1[3]='<a href="#" onclick="return clickreturnvalue()" onmouseover="dropdownmenu(this, event, menu3, '150px')" onmouseout="delayhidemenu()">Discipleship</a>'
- menu1[4]='<a href="/care.shtml">Care</a>'
- menu1[5]='<a href="#" onclick="return clickreturnvalue()" onmouseover="dropdownmenu(this, event, menu4, '150px')" onmouseout="delayhidemenu()">Youth/Children</a>'
- //Contents for Worship Menu
- var menu2=new Array()
- menu2[0]='<a href="/choir.shtml">Choir</a>'
- //Contents for Discipleship Menu
- var menu3=new Array()
- menu2[0]='<a href="/smallGroup.shtml">Small Groups</a>'
- menu2[1]='<a href="/sunSchool.shtml">Sunday School</a>'
- //Contents for Youth/Children
- var menu4=new Array()
- menu2[0]='<a href="/youth.shtml">Middle/High School</a>'
- menu2[1]='<a href="/children.shtml">Preschool/Children</a>'
- //Contents for Resources
- var menu5=new Array()
- menu2[0]='<a href="/message.shtml">Message Board</a>'
- menu2[1]='<a href="/links.shtml">Links</a>'
- //Declare Menu variables
- var menuwidth='165px' //default menu width
- var menubgcolor='#3B3B65' //menu bgcolor
- var disappeardelay=250 //menu disappear speed onMouseout (in miliseconds)
- var hidemenu_onclick="yes" //hide menu when user clicks within menu?
- /////No further editting needed
- var ie4=document.all
- var ns6=document.getElementById&&!document.all
- if (ie4||ns6)
- document.write('<div id="dropmenudiv" style="visibility:hidden;width:'+menuwidth+';background-color:'+menubgcolor+'" onMouseover="clearhidemenu()" onMouseout="dynamichide(event)"></div>')
- function getposOffset(what, offsettype){
- var totaloffset=(offsettype=="left")? what.offsetLeft : what.offsetTop;
- var parentEl=what.offsetParent;
- while (parentEl!=null){
- totaloffset=(offsettype=="left")? totaloffset+parentEl.offsetLeft : totaloffset+parentEl.offsetTop;
- parentEl=parentEl.offsetParent;
- }
- return totaloffset;
- }
- function showhide(obj, e, visible, hidden, menuwidth){
- if (ie4||ns6)
- dropmenuobj.style.left=dropmenuobj.style.top="-500px"
- if (menuwidth!=""){
- dropmenuobj.widthobj=dropmenuobj.style
- dropmenuobj.widthobj.width=menuwidth
- }
- if (e.type=="click" && obj.visibility==hidden || e.type=="mouseover")
- obj.visibility=visible
- else if (e.type=="click")
- obj.visibility=hidden
- }
- function iecompattest(){
- return (document.compatMode && document.compatMode!="BackCompat")? document.documentElement : document.body
- }
- function clearbrowseredge(obj, whichedge){
- var edgeoffset=0
- if (whichedge=="rightedge"){
- var windowedge=ie4 && !window.opera? iecompattest().scrollLeft+iecompattest().clientWidth-15 : window.pageXOffset+window.innerWidth-15
- dropmenuobj.contentmeasure=dropmenuobj.offsetWidth
- if (windowedge-dropmenuobj.x < dropmenuobj.contentmeasure)
- edgeoffset=dropmenuobj.contentmeasure-obj.offsetWidth
- }
- else{
- var topedge=ie4 && !window.opera? iecompattest().scrollTop : window.pageYOffset
- var windowedge=ie4 && !window.opera? iecompattest().scrollTop+iecompattest().clientHeight-15 : window.pageYOffset+window.innerHeight-18
- dropmenuobj.contentmeasure=dropmenuobj.offsetHeight
- if (windowedge-dropmenuobj.y < dropmenuobj.contentmeasure){ //move up?
- edgeoffset=dropmenuobj.contentmeasure+obj.offsetHeight
- if ((dropmenuobj.y-topedge)<dropmenuobj.contentmeasure) //up no good either?
- edgeoffset=dropmenuobj.y+obj.offsetHeight-topedge
- }
- }
- return edgeoffset
- }
- function populatemenu(what){
- if (ie4||ns6)
- dropmenuobj.innerHTML=what.join("")
- }
- function dropdownmenu(obj, e, menucontents, menuwidth){
- if (window.event) event.cancelBubble=true
- else if (e.stopPropagation) e.stopPropagation()
- clearhidemenu()
- dropmenuobj=document.getElementById? document.getElementById("dropmenudiv") : dropmenudiv
- populatemenu(menucontents)
- if (ie4||ns6){
- showhide(dropmenuobj.style, e, "visible", "hidden", menuwidth)
- dropmenuobj.x=getposOffset(obj, "left")
- dropmenuobj.y=getposOffset(obj, "top")
- dropmenuobj.style.left=dropmenuobj.x-clearbrowseredge(obj, "rightedge")+"px"
- dropmenuobj.style.top=dropmenuobj.y-clearbrowseredge(obj, "bottomedge")+obj.offsetHeight+"px"
- }
- return clickreturnvalue()
- }
- function clickreturnvalue(){
- if (ie4||ns6) return false
- else return true
- }
- function contains_ns6(a, b) {
- while (b.parentNode)
- if ((b = b.parentNode) == a)
- return true;
- return false;
- }
- function dynamichide(e){
- if (ie4&&!dropmenuobj.contains(e.toElement))
- delayhidemenu()
- else if (ns6&&e.currentTarget!= e.relatedTarget&& !contains_ns6(e.currentTarget, e.relatedTarget))
- delayhidemenu()
- }
- function hidemenu(e){
- if (typeof dropmenuobj!="undefined"){
- if (ie4||ns6)
- dropmenuobj.style.visibility="hidden"
- }
- }
- function delayhidemenu(){
- if (ie4||ns6)
- delayhide=setTimeout("hidemenu()",disappeardelay)
- }
- function clearhidemenu(){
- if (typeof delayhide!="undefined")
- clearTimeout(delayhide)
- }
- if (hidemenu_onclick=="yes")
- document.onclick=hidemenu
- And on the shtml page:
- <table width="900px" border="1" cellspacing="0" cellpadding="0">
- <tr>
- <td align="center">
- <a href="/default.shtml">Home</a>
- </td>
- <td align="center">
- <a href="default.shtml" onClick="return clickreturnvalue()" onMouseOver="dropdownmenu(this, event, menu1, '150px')" onMouseOut="delayhidemenu()">Ministries</a>
- </td>
- <td align="center">
- <a href="/calendar.shtml">Calendar</a>
- </td>
- <td align="center">
- <a href="/about.shtml">About</a>
- </td>
- <td align="center">
- <a href="/contact.shtml">Contact Us</a>
- </td>
- <td align="center">
- <a href="#" onClick="return clickreturnvalue()" onMouseOver="dropdownmenu(this, event, menu5, '150px')" onMouseOut="delayhidemenu()">Resources</a>
- </td>
- </tr>
- </table>
- And the .css:
- #dropmenudiv{
- position:absolute;
- border:1px solid black;
- border-bottom-width: 0;
- font:normal 12px Verdana;
- line-height:18px;
- z-index:100;
- }
- #dropmenudiv a{
- width: 100%;
- display: block;
- text-indent: 3px;
- border-bottom: 1px solid black;
- padding: 1px 0;
- text-decoration: none;
- font-weight: bold;
- }
- #dropmenudiv a:hover{ /*hover background color*/
- background-color: #7AD0E1;
- }